home *** CD-ROM | disk | FTP | other *** search
/ Speccy ClassiX 1998 / Speccy ClassiX 98.iso / amiga_system / the_aminet / dev / gcc / ixemulsrc.lha / ixemul-41.4 / library / kmalloc.c < prev    next >
C/C++ Source or Header  |  1995-05-27  |  3KB  |  113 lines

  1. /*
  2.  *  This file is part of ixemul.library for the Amiga.
  3.  *  Copyright (C) 1991, 1992  Markus M. Wild
  4.  *
  5.  *  This library is free software; you can redistribute it and/or
  6.  *  modify it under the terms of the GNU Library General Public
  7.  *  License as published by the Free Software Foundation; either
  8.  *  version 2 of the License, or (at your option) any later version.
  9.  *
  10.  *  This library is distributed in the hope that it will be useful,
  11.  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
  12.  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  13.  *  Library General Public License for more details.
  14.  *
  15.  *  You should have received a copy of the GNU Library General Public
  16.  *  License along with this library; if not, write to the Free
  17.  *  Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  18.  *
  19.  *  kmalloc.c,v 1.1.1.1 1994/04/04 04:30:54 amiga Exp
  20.  *
  21.  *  kmalloc.c,v
  22.  * Revision 1.1.1.1  1994/04/04  04:30:54  amiga
  23.  * Initial CVS check in.
  24.  *
  25.  *  Revision 1.3  1992/08/09  20:57:37  amiga
  26.  *  add declaration
  27.  *
  28.  *  Revision 1.2  1992/05/22  01:43:35  mwild
  29.  *  use buddy-alloc memory management
  30.  *
  31.  * Revision 1.1  1992/05/14  19:55:40  mwild
  32.  * Initial revision
  33.  *
  34.  */
  35.  
  36. #define KERNEL
  37. #include "ixemul.h"
  38. #include "kprintf.h"
  39.  
  40. #include <exec/memory.h>
  41. #include <stdio.h>
  42.  
  43. #ifndef BARE_ALLOCMEM
  44. #define AllocMem(size,attr)    b_alloc(size,attr)
  45. #define FreeMem(buf,size)    b_free(buf,size)
  46. void *b_alloc(int,int);
  47. void b_free(void *,int);
  48. #endif
  49.  
  50. void kfree (void *);
  51.  
  52. /* This is a very simple and crude malloc package, only intended to
  53.    be used inside the library. We don't record what we allocated, as all
  54.    allocations are inside objects that are resource tracked, so no memory
  55.    should be lost (currently write buffers and memory files are allocated
  56.    with these functions) */
  57.  
  58.  
  59. void *
  60. kmalloc (size_t size)
  61. {
  62.   u_int *res;
  63.  
  64.   /* always allocate a quantity of long words so we can CopyMemQuick() later */
  65.   size = (size + 3) & ~3;
  66.  
  67.   res = (u_int *) AllocMem (size + 4, MEMF_PUBLIC);
  68.   if (res) *res++ = size;
  69.  
  70.   return res;
  71. }
  72.  
  73. void *
  74. krealloc (void *mem, size_t size)
  75. {
  76.   u_int *res;
  77.  
  78.   if (! mem) return kmalloc (size);
  79.  
  80.   /* always allocate a quantity of long words */
  81.   size = (size + 3) & ~3;
  82.  
  83.   /* in that case the block is already large enough */
  84.   if (((u_int *)mem)[-1] >= size)
  85.     return mem;
  86.  
  87.   res = (u_int *) AllocMem (size + 4, MEMF_PUBLIC);
  88.   if (res)
  89.     {
  90.       *res++ = size;
  91.       CopyMemQuick (mem, res, ((u_int *)mem)[-1]);
  92.  
  93.       /* according to the manpage, the old buffer should only be
  94.        * freed, if the allocation of the new buffer was successful */
  95.       kfree (mem);
  96.     }
  97.  
  98.   return res;
  99. }
  100.  
  101. void
  102. kfree (void *mem)
  103. {
  104.   u_int *res;
  105.   
  106.   if (! mem) return;
  107.  
  108.   res = mem;
  109.   res--;
  110.  
  111.   FreeMem (res, *res + 4);
  112. }
  113.